package com.guigui.gulimall.ware.dao;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.guigui.gulimall.ware.entity.WareSkuEntity;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * 商品库存
 * 
 * @author xin
 * @email 806748502@qq.com
 * @date 2021-07-23 16:07:56
 */
@Mapper
public interface WareSkuDao extends BaseMapper<WareSkuEntity> {

    void addWare(@Param("skuId") Long skuId, @Param("wareId") Long wareId, @Param("skuNum") Integer skuNum);

    /**
     * 通过skuId获取库存数量
     */
    Long getStock(@Param("skuId") Long skuId);

    /**
     * 锁库存
     */
    Integer lockProduct(@Param("skuId") Long skuId, @Param("count") Integer count, @Param("wareId") Long wareId);

    /**
     * 那个仓库有库存
     * @param skuId 商品
     * @param count 数量
     * @return 仓库list
     */
    List<Long> queryWhereStockBySkuId(@Param("skuId") Long skuId, @Param("count") Integer count);

    /**
     * 解锁库存
     * @param wareId 仓库
     * @param skuId 商品
     * @param skuNum 数量
     */
    void unLockStock(@Param("wareId") Long wareId, @Param("skuId") Long skuId, @Param("skuNum") Integer skuNum);
}
